草庐IT

java - 搜索功能的 SQL 查询

全部标签

ruby-on-rails - 在 Rails 中添加 created_at DESC 功能

我有一个带有帖子和评论模型的应用程序。在我的索引操作/View中,我遍历帖子并从最近创建时间到最早创建时间显示它们。我的评论嵌套在我的帖子中,因此在我的帖子显示操作/View中,我想遍历评论并让它们显示从最近创建到最早创建的时间。如果我在我的post.rb文件中创建一个方法,我似乎只能让它工作。我有这个:post.rb:defnewest_commentsself.comments.order("created_atDESC")end在我的帖子展示View中,我可以遍历帖子评论并且效果很好:但我想在Controller层设置此功能,但我不知道如何设置。这是我在我的帖子Controlle

ruby - 如何打开一个文件并搜索一个词?

如何使用Ruby打开文件并在其中搜索单词? 最佳答案 所有提出的解决方案的时间复杂度都是O(n)。为简单起见,我使用String#include?来检查单词。这可以用string=~regex形式的正则表达式代替。阅读完整文件并在其中搜索。File.read(filename).include?(word)如果您的文件非常大,这不是最佳解决方案,因为您会将整个文件读入内存,然后再开始搜索。你的内存复杂度是O(n)逐行读取文件并在每一行中搜索File.open(filename)do|f|f.any?do|line|line.incl

ruby-on-rails - 具有多态关联的范围和查询

关于如何在Rails中为多态关联编写作用域,我发现的很少,更不用说如何在多态关联上编写查询了。在Rails文档中,我查看了PolymorphicAssociationssection,JoiningTablessection,和Scopessection.我也做了我应得的谷歌搜索。以这个设置为例:classPet所以宠物可以是animal_type“狗”、“猫”或“鸟”。要显示所有表结构:这是我的schema.rb:create_table"birds",force::cascadedo|t|t.datetime"created_at",null:falset.datetime"upd

sql - 在 Rails 中使用连接执行 update_all

在这种情况下,Rails对原始SQL的抽象让我抓狂。在MySQL中我可以这样做:UPDATEFROMtasksAStLEFTJOINprojectsaspONt.project_id=p.idSETt.invoice_id=7WHEREp.organization_id==42ANDt.invoice_idISNULL我如何在Rails3.0.1中使用预先加载来做到这一点?我已经尝试了以下所有方法:Tasks.joins(:project).where('projects.organization_id'=>42,:invoice_id=>nil).update_all(:invoic

sql - 如何查看 SQL ActiveRecord 生成的内容?

我想检查一些由ActiveRecord生成的查询,但我不需要实际运行它们。有没有办法在返回结果之前获取查询? 最佳答案 这两篇文章都应该可以帮助您做您想做的事。http://weblog.jamisbuck.org/2007/1/8/watching-activerecord-do-it-s-thinghttp://weblog.jamisbuck.org/2007/1/31/more-on-watching-activerecord 关于sql-如何查看SQLActiveRecord生

sql - 用于 250K+ 字符串的通配符搜索的 Fast(er) 方法

我在MySQL数据库中有一个英语词典,其中只有超过250K个条目,我正在使用一个简单的ruby​​前端在字符串的开头使用通配符来搜索它。到目前为止,我一直这样做:SELECT*FROMwordsWHEREwordLIKE'_e__o'甚至SELECT*FROMwordsWHEREwordLIKE'____s'我总是知道单词的确切长度,但除了一个字符之外的所有字符都可能是未知的。这比糖蜜慢,比没有前导通配符的类似查询慢大约15倍,因为无法使用该列的索引。我尝试了几种方法来缩小搜索范围。例如,我添加了26个额外的列,其中包含每个单词的单个字母计数,并首先使用这些列来缩小搜索范围。我也试过按

Ruby 的 vcr 的 Java 替代品?

是否有Ruby'sVCR的java替代品??据我所知,使用VCR的好处是巨大的,您可以运行“集成测试”并记录结果,将它们存储在本地某个地方。现在,从下次需要运行测试时起,您可以使用第一次运行时记录的数据模拟实际数据库命中。Java世界中有类似的东西吗?如果没有,如果我尝试实现它可能会遇到什么样的瓶颈?VCR只记录HTTP交互,但是否可以采用这种方法来记录,比如对其他团队的API的任何类型的数据库操作/函数调用,我不需要测试,基本上这将使我免于模拟所以通过自动化来完成很多事情。Here是带有Ruby单元测试的VCR示例: 最佳答案 查

ruby-on-rails - Rails 使用逻辑运算符搜索 ActiveRecord

我想知道在Rails中解析文本查询的最佳方法是什么,以允许用户包含逻辑运算符?我希望用户能够输入其中任何一个,或一些等效的:#searchingpartialtextinemails,justforexample#queryA"jonANDgmail"#=>["jonsmith@gmail.com"]#queryB"jonORgmail"#=>["jonsmith@gmail.com","sarahcalaway@gmail.com"]#queryC"jonANDgmailANDsmith"#=>["jonsmith@gmail.com"]理想情况下,我们可以使用括号来指示操作顺序,从

ruby-on-rails - 开始对 Ruby Rails 网站进行单元和功能测试的最佳方法是什么?

我正在测试一个RubyRails网站,想开始进行单元和功能测试。 最佳答案 Cucumber和RSpec值得一看。他们鼓励在behaviour-driven中进行测试,基于示例的样式。RSpec是一个用于单元级测试的库:describe"hello_world"it"shouldsayhellototheworld"do#RSpeccomeswithitsownmock-objectframeworkbuiltin,#thoughitletsyouuseothersifyoupreferworld=mock("World",:pop

ruby-on-rails - Development.log 日志文件不记录 Rails SQL 查询

我在这里关注MichaelHartl的Rails教程:http://ruby.railstutorial.org/chapters/modeling-and-viewing-users-one#top我使用此命令在单独的窗口中跟踪SQL查询:tail-flog/development.log然而,当我在沙盒Rails控制台中时,日志不会用SQL语句更新,而是显示在Rails控制台中。我该如何纠正这种行为?我应该补充一点,我的数据库迁移和对数据模型(新表等)的更改都反射(reflect)在日志中。仅省略由Rails控制台内的方法传播的SQL语句(而是显示在Rails控制台中)。这是我的G